package Leetcode第一期;

import java.util.Arrays;

/**
 * @author : K k
 * @date : 9:40 2020/5/16
 * 给你两个有序整数数组 nums1 和 nums2，请你将 nums2 合并到 nums1 中，使 nums1 成为一个有序数组。
 *
 *  
 *
 * 说明:
 *
 * 初始化 nums1 和 nums2 的元素数量分别为 m 和 n 。
 * 你可以假设 nums1 有足够的空间（空间大小大于或等于 m + n）来保存 nums2 中的元素。
 *  
 *
 * 示例:
 *
 * 输入:
 * nums1 = [1,2,3,0,0,0], m = 3
 * nums2 = [2,5,6],       n = 3
 *
 * 输出: [1,2,2,3,5,6]
 */
public class 合并两个有序数组_88 {

    //先合并再排序
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        System.arraycopy(nums2, 0, nums1, m, n); //从nums1的0开始到n-1 copy到nums2的m位置
        Arrays.sort(nums1);
    }

    public void mergeA(int[] nums1, int m, int[] nums2, int n) {
        int p=nums1.length-1;
        int p1=m-1;
        int p2=n-1;

        while (p2>=0&&p1>=0){
            if (nums2[p2]>=nums1[p1]){
                nums1[p]=nums2[p2];
                p--;
                p2--;
            }else {
                nums1[p]=nums1[p1];
                p--;
                p1--;
            }
            p2--;
        }
        //将nums2中的丢失的数
        System.arraycopy(nums2, 0, nums1, 0, p2 + 1);
    }
}
